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METHOD FOR DYNAMIC CUSTOMER PROFILING IN DATABASE 

CROSS-REFERENCES TO RELATED APPLICATIONS 
This application claims priority from the following U.S. Provisional Patent 
5 Application, the disclosure of which, including all appendices and all attached documents, 
is incorporated by reference in its entirety for all purposes: 

U.S. Provisional Patent Application Serial No. 60/125,721 Li- Wen Chen 
entitled, "METHOD AND APPARATUS FOR PERFORMING CUSTOMER 
BEHAVIOR ASSOCIATION ANALYSIS," (Attorney Docket Number 19608- 
10 000400US) filed March 23, 1999. 



BACKGROUND OF THE INVENTION 
The present invention relates generally to computer database systems, and 
specifically to methods for visualizing information from a data warehousing environment, 

1 5 Few could foresee the rapid development of computer technology just a 

few years ago. Computers now have a place in our homes, our offices, our schools and 
even our briefcases and satchels. As computer automation continues to impact an ever 
increasing portion of our daily lives, governments, businesses and individuals have turned 
to database technology to help them manage the "information explosion," the exponential 

20 proliferation of information that must be sorted, assimilated and managed on a continuing 
basis. One area of importance to the database design field is data model selection for 
database applications. 

A data model represents the structure or organization of data stored in the 
database. It enables the use of data in certain forms and may limit the data being used in 

25 other forms. Different applications usually require different data models. Many different 
data models can exist, and they usually differ markedly from one another. Typically, 
database applications are customized to a particular data model of a particular database. 
Usually, these applications must be re-implemented for every database, even though the 
functioning of the application remains the same. 

30 Presently, database developers have turned to data warehousing 

technology to resolve often conflicting data management requirements. Traditional data 
warehousing approaches focus on decision support applications, which emphasize 
summarized information. While perceived advantages exist, an inherent disadvantage to 
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1 these systems is that the customer identity is lost. Further, usability of customer data 
analyses techniques can be improved over traditional approaches by methods for 
displaying analysis results and database content to the user. 

What is needed is a method for analyzing customer data contained in 
5 databases, data marts and data warehouses. 



SUMMARY OF THE INVENTION 
According to the invention, techniques for profiling of human behavior 

10 based upon analyzing data contained in databases, data marts and data warehouses are 
provided. In an exemplary embodiment, the invention provides a method for creating a 
dynamic customer profile by analyzing relationships in data from one or more data 
sources of an enterprise. The method can be used with many popular visualization tools, 
such as On Line Analytical Processing (OLAP) tools and the like. The method is 

15 especially useful in conjunction with a meta-model based technique for modeling the 
enterprise data. The enterprise is typically a business activity, but can also be other loci 
of human activity. The human behavior profiled is typically that of a customer, but can 
be any other type of human behavior. Embodiments according to the invention can 
display data from a variety of sources in order to provide visual representations of data in 

20 a data warehousing environment. 

A first aspect in accordance with the present invention provides a method 
for creating a customer profile from customer information. The customer information can 
be stored in a database, multiple databases, a data mart or a data warehouse, for example. 
The customer information can comprise one or more attributes. Attributes can include 

25 age, gender, income, and the like. The method can include receiving as input the 

customer information. Receiving can be by means of direct input, or by accessing data in 
a legacy database, for example. Segmenting the customer information into one or more 
groups, or segments, based upon a value for the attributes can also be part of the method. 
The method can also include defining one or more profiles. Profiles can comprise one or 

30 more groups. The profiles can be used to analyze the customer information. 

In a specific embodiment, the segmenting can include specifying one or 
more expressions, in which each expression can be evaluated to a particular value. The 
expression can comprise one or more attributes, where the attributes can be combined 
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based upon one or operators. Operators can include arithmetic operators, logical 
operators, and the like. 

In another specific embodiment, segmenting can include mapping values 
produced by the one or more expressions to one or more segmentation code values. The 

5 method can also include assigning numeric values to particular ones of the segmentation 
code values. The method can also include assigning enumerative values to particular 
ones of said plurality of segmentation code values. The method can also include mapping 
a range of expression values to the one or more segmentation code values. 

Numerous benefits are achieved by way of the present invention over 

10 conventional techniques. The present invention can provide techniques for profiling 

human behavior based upon dynamic relationships that can be customized to fit different 
business needs. Many embodiments enable business applications to be built more easily 
and quickly than heretofore known methods. These and other benefits are described 
throughout the present specification. A further understanding of the nature and 

1 5 advantages of the invention herein may be realized by reference to the remaining portions 
of the specification and the attached drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 
Fig. 1 illustrates a representative computer system suitable for 
20 implementing a particular embodiment according to the present invention; 

Fig. 2 illustrates in a representative embodiment according to the present 

invention; 

Fig. 3 illustrates in a representative embodiment according to the present 

invention; 

25 Figs. 4A-4C illustrate representative flowcharts of simplified process steps 

according to an embodiment of the present invention; and 

Figs. 5A-5I illustrate example screens in a representative embodiment 
according to the present invention. 

30 DESCRIPTION OF THE SPECIFIC EMBODIMENTS 

Embodiments according to the present invention can provide techniques 
for creating and using dynamic profiles of consumer behavior based upon data present in 
enterprise information processing systems for analysis and the like. 
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Dynamic profiling techniques according to the present invention enable 
analysis of customers based upon selected criteria using segmentation techniques. 
Specific embodiments according to the present invention provide frameworks for users to 
create and manage customer centric data warehouses having a wide variety of data 
5 models such as a star schema data model, a reverse star schema data model and the like. 
Such data warehouses can avail themselves of analytical functions such as Market Basket 
Analysis (MBA), Regency/Frequency/Monetary Analysis (RFMA), and the like. In some 
embodiments, dynamic profiling techniques can include graphical user interfaces (GUI) 
that enable users to define segmentation schemes for customers and then generate 

1 0 database data based upon the segmentation. This database data can then be incorporated 
into the data warehouse for use in additional analysis by the user. Some specific 
embodiments can also include tools that enable profiling of data for use by Online 
Analytical Processing (OLAP) tools. 

In a specific embodiment, usage scenarios, or models, can incorporate 

15 dynamic profiling techniques. In a representative example, a bank may want to know 
how much profit each customer is contributing to the bank's bottom line, and then 
segment the customers based upon the individual contributions to profitability. 
Accordingly, this example bank can build a profitability model by calculating the 
profitability of each individual customer, then defining a customer segmentation, e.g., by 

20 percentile, for example, and then defining how the segmented data can be viewed using 
visualization tools such as OLAP tools, for example. In this representative example, the 
bank can produce a data warehouse having profiling information that is suitable for 
viewing using popular visualization tools such as OLAP tools, Excel 2000 and the like. 

While embodiments according to the present invention are discussed 

25 generally using representative examples, such as the bank, the present invention is readily 
applicable to a wide variety of business types, industries and business relationships, such 
as retailing, electronic commerce, telephone-based catalog selling, insurance applications, 
banking and credit applications, telecommunications and entertainment (e.g. satellite and 
cable TV service) services, and the like. Thus, the examples used herein are intended to 

30 be illustrative and not limiting. 

Specific embodiments according to the present invention can include 
customer profiling techniques such as segmentation assignment and profile composition, 
for example. Segmentation assignment can comprise partitioning customers into a 
plurality of groups, or segments, based upon certain attributes, or derived attributes, of the 
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customers. Profile composition can comprise combining one or more groups, or 
segments, provided by the segmentation assignment into a one or more profiles. For 
example, a representative database can include an age attribute for each customer. 

Table 1 illustrates a particular embodiment in which a segmentation 
5 scheme based upon an age attribute is used to segment customers into 3 groups. 



Age greater than 


Age less than 


Segment code value 


>10 


<20 


1 


>20 


<50 


2 


otherwise 




3 



Table 1 



In the representative organization illustrated by Table 1, a segment code 

10 value of 1, 2 or 3 can be assigned to a customer based upon the value of the age attribute. 
For example, customers having an age greater than 10 and less than 20 can be assigned a 
segment code value of 1 . Customers having an age greater than or equal to 20 and less 
than 50 are assigned a segment code value of 2. All other customers are assigned a 
segment code value of 3. This effectively segments the customers into three groups based 

15 upon the age attribute. Similarly, an income attribute can be used to segment customers 
in another segment scheme. Other attributes can also be used by specific embodiments 
according to the present invention without departing from the scope of the claims herein. 

In a specific embodiment according to the present invention, segmentation 
assignment can comprise specifying an expression which evaluates to a specific value. In 

20 the example above, the expression is a single quantity; the attribute age. However, in 
some specific embodiments according to the present invention, expressions can comprise 
a plurality of customer attributes that can be combined based upon one or more operators 
including arithmetic operators, logical operators, and the like. Resultants obtained from 
evaluating expressions can then be used to determine the assignment of customers to 

25 segments. Further, embodiments can perform segmentation based upon expressions that 
aggregate attributes from sources other than customer information such as purchase 
transaction information and the like. Many other specific embodiments can include a 
plurality of expressions for segmenting customers based upon any number of 
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combinatorial functions such as Boolean expressions and so forth without departing from 
the scope of the claims herein. 

Specific embodiments can comprise mapping the values produced by 
various expressions to one or more segmentation code values. This mapping comprises 

5 an assignment of numeric values and enumerative values to particular segmentation 
codes. The representative example discussed above regarding segmentation based upon 
age defines a range assignment. Range assignments can map ranges of expression values 
to particular segmentation codes. Specific embodiments can include percentile 
assignments, which can segment customers based upon an expression value and map the 

10 customers by percentile to a particular segment code value. For example, as illustrated in 
Table 2, the top 20 percent of customers are assigned a segment code value of I. The 
next 30 percent of customers are assigned a segment code value of 2. All other customers 
are assigned a value of 3. 



Age 


Segment code value 


Top 20% 


1 


Next 30% 


2 


other 


3 



15 

Table 2 - 

Expressions can evaluate to non-numeric values, as well The assignment 
can specify enumeratively, what expression value maps to a particular segment code 
20 value. For example, Table 3 illustrates a particular mapping of enumerative values, in 
this example; titles, to particular segment code values. 



Title 


Segment code value 


"CEO" 


1 


"Vice President" 


2 ' 


"Manager" 


3 


Other 


4 



Table 3 



6 



WO 00/57312 PCT/USOO/0781 4 

Table 3 illustrates a representative example wherein a title CEO is mapped 
to a segment code value of I. The Vice President is mapped to a segment code value 
of 2. The manager is mapped to a segment code value of 3 and all others are mapped to a 

5 segment code value of 4. 

In some specific embodiments, profiles can provide finer segmentation of 
customers than individual segmentation codes. For example, a profile can be defined 
based upon an age segmentation and an income segmentation. This example profile can 
be named "Profile 1", or more meaningfully, "Age Income Profile," for example. This 

10 example profile comprises age and income segmentation data and can be denoted using a 
nomenclature ("A", "I"). Further, in some embodiments different profiles can be created 
from the same segmentation codes. In another example, suppose R, F, M, P, A and I 
represent segmentation codes of certain attributes of interest. For example, R = recency, 
F = frequency, M = monetary, P = profitability, A = age, and I = income. From these 

15 segment codes then, a particular profile can be created that comprises (R, F, M). Further, 
another profile can be created that comprises (R, P, A), and so forth for other subsets of 
the segmentation codes. Such profiles can provide the capability to reuse defined 
segmentation assignments in composite arrangements. Table 4 illustrates two profiles 
that are based upon segmentation codes A, I, R, F, M and P. 

20 



Profile Name 


Composition 


"profile 1" 


R, F, M 


"Profile 2" 


A, P 



Table 4 



Table 4 illustrates a profile 1 comprising segmentation codes R, F and M. 
25 Table 4 also illustrates a profile 2 comprising segmentation codes A and P. In this 

particular representative example, profiles 1 and 2 are created by applying AND predicate 
to the constituent segment codes. Accordingly, in the example of Table 4, profile 1 
specifies customers having segmentation codes (R, F, M) = (1, 1 , 1) as belonging to a first 
segment, while (1,1,2) and (1, 1,3) belong to second and third segments. This "profile" 
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mechanism basically provides a way to group customers into finer segments by 
combining existing segment codes to create more meaningful categories. 

Fig. 1 illustrates a representative computer system suitable for 
implementing a particular embodiment according to the present invention. This diagram 
5 is merely an illustration and should not limit the scope of the claims herein. One of 
ordinary skill in the art would recognize other variations, modifications, and alternatives. 
Fig. 1 shows basic subsystems of a computer system 1 13 suitable for use with the present 
invention. In Fig. 1, computer system 1 13 includes a bus 1 15 which interconnects major 
subsystems such as a central processor 1 14, a system memory 1 16, an input/output 

10 controller 1 18, an external device such as a printer (not shown), a display screen 124 via a 
display adapter 126, a serial port 128, a keyboard 132, a fixed disk drive 144 and a 
removable disk drive 136 operative to receive a removable disk 138, Many other devices 
may be connected such as a scanner (not shown) via I/O controller 1 18, a mouse 146 
connected to serial port 128 or a network interface 148. Many other devices or 

15 subsystems (not shown) may be connected in a similar manner. Also, it is not necessary 
for all of the devices shown in Fig. 1 to be present to practice the present invention, as 
discussed below. The devices and subsystems may be interconnected in different ways 
from that shown in Fig. 1. Source code to implement the present invention may be 
operably disposed in system memory 1 16 or stored on storage media such as a fixed 

20 disk 144 or a removable disk 138. 

In a presently preferable embodiment according to the present invention, a 
method for providing customer data analysis capabilities heretofore unknown in the prior 
art can be operably disposed in the system memory 1 1 6 or fixed disk 144 of system 1 13 
of Fig. 1. Customer data analysis can include, but is not limited to, decision support 

25 analysis that relates business decisions to customer behavior. Customer data analysis 
applications can analyze data based on customer identity and correlate customer 
activities, events, transactions, and status to the customers' identity.. Techniques such as 
decision support applications, summarizing techniques and the like can also be used 
without departing from the scope of the present invention. 

30 A data model represents an organization of data in a database. Choice of a 

data model facilitates the use of data in certain ways and may limit the use of data in 
others. Different applications typically require different data models that are usually 
quite different from one another. Thus, database applications are typically customized to 
the data model used by the database. These applications can be implemented for 

8 
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databases having different data models even though the underlying logic of the 
application may be similar. A meta model is an abstract data model that describes 
relationships between different entities or groups of entities in a data model. Applications 
designed and developed in accordance with a particular meta model can be reused in 

5 other similar situations. Applications can be readily customized by exposing 

customizable details as meta data to application code. Thus, applications can customize a 
data model by following the relationships described in the meta model 

Application developers can consider tradeoffs among competing factors 
when creating a meta model Some of these factors are; 1) the ability to customize the 

10 data model to fit different business application needs; 2) flexibility in designing re-usable 
application code; and 3) the usefulness of the application when using a particular 
specialized data model 

Database applications can be written to conform to a meta model and refer 
to the detailed data model through means such as a data dictionary, for example. These 

15 and other techniques according to the present invention enable application code to be 

reusable. One example of a data model/meta model combination is the star schema/multi- 
dimensional model combination that can be useful in data warehouse applications. In this 
combination, the star schema comprises a "universal data model" and the multi- 
dimensional model comprises a meta model. 

20 Data warehouses can use multi-dimensional models, such as meta models, 

to conceptualize business operations, for example. Such meta models can simplify tasks 
of analyzing and understanding the performance or efficiencies of business operations. 
Multi-dimensional models can provide "macro" views of the business performance, for 
example. Such views can be highly summarized in order to show the company 

25 executives a clear "big picture" of the business. Each piece of data can be indexed by 
multiple business processes, aspects, and the like in order to illustrate data from different 
view points to the executives. 

In specific embodiments, profiling can be implemented by means of data 
structures. The data structures can include meta data that can record how segmentation 

30 assignments and profiles are performed, so that the process can be repeated, for example. 
Results of a segmentation segmentation and profiling can also be stored in a data 
structure. This data structure can be used to generate database tables and the like. 

Fig. 2 illustrates a representation of a data tables in a particular 
embodiment according to the present invention. This diagram is merely an illustration 



WO 00/57312 PCT/USOO/07814 

' and should not limit the scope of the claims herein. One of ordinary skill in the art would 
recognize other variations, modifications, and alternatives. Fig. 2 illustrates example 
database tables, including a first table 201, containing segment code values, 
CI_segjcodes, and a second table 203, containing profiles, CI _profiles. Tables 201 and 
5 203 can be created from the segmentation coding and profiling as described herein. First 
table 201 can be linked to a table containing customer data, such as customer data table 
200, for example. Accordingly, tables 201 and 203 can serve as extensions of customer 
table 200. Columns in tables 201 and 203 can represent segment code values and profile 
identifiers for customers, and the like. For example; table 201 illustrates a customer (cid) 

10 "1", having an "R" code value of "1" and an "F" code value of "2". Similarly, table 203 
illustrates that this customer has a profile identifier under "Profile_l" of "3." Further, 
table 203 can be linked to profile tables, such as profile table 205, CI j>rofile_l in this 
example, and profile table 207, CI _prqfile__2 in this example. Accordingly, the Profile_l 
identifier is linked to profile table 205, which corresponds to an (R, F, M) = (1 , 2, 1) for 

15 the customer whose cid is "1" in table 203. 

Fig, 3 illustrates a representation of a data model in a particular 
embodiment according to the present invention. This diagram is merely an illustration 
and should not limit the scope of the claims herein. One of ordinary skill in the art would 
recognize other variations, modifications, and alternatives. Fig. 3 illustrates a repository 

20 information model 301. Datamodel30i illustrates a project 302 having can contain 

multiple profiles, which is in turn composed of one or more segment codes. Each code is 
defined by an expression and segment mapping (ranges, percentile or enumeration). 

Specific embodiments can provide graphical user interfaces that facilitate 
creating dynamic profiling data and processing the data to produce database tables. 

25 Figs. 5A-5I illustrate various screens of a graphical user interface that can be used in a 
representative embodiment according to the present invention. These diagrams are 
merely illustrations and should not limit the scope of the claims herein. One of ordinary 
skill in the art would recognize other variations, modifications and alternatives. 

Fig. 4A depicts a simplified flow diagram for the method for creating a 

30 customer profile in a particular embodiment according to the present invention. This 

diagram is merely an example which should not limit the scope of the claims herein. One 
of ordinary skill in the art would recognize many other variations, alternatives, and 
modifications. Fig. 4 A illustrates flow diagram 401 having a step 402 of accessing 
customer information. The customer information can be retrieved from a database, data 
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mart or data warehouse, for example. The customer information can be accessed from a 
data warehousing environment, comprising one or more legacy databases, for example, 
coupled with one or more servers and accessible by one or more client computers. In 
some embodiments, the customer information can also be accessed across a computer 

5 network or the Internet, for example. Then, a step 404 of segmenting customer 
information into one or more groups of customers can be performed. The customer 
information can comprise one or more attributes. The segmenting can be based upon a 
value for the attribute or attributes of interest. A step 406 of defining one or more profiles 
can also be part of the method, A profile can comprise one or more groups. Then, in a 

10 step 408, the customer profile can be used to analyze the customer information. Results 
of the analysis of step 408 can be used for a plurality of uses. The marketer can 
determine the efficacy of her marketing mix, for example. A product planner of a large 
multi-national corporation can determine whether to entire a new line of business, or 
divest an existing line of business. 

15 Fig. 4B depicts a simplified flow diagram of determining step 404 of Fig. 

4A in a particular embodiment according to the present invention. This diagram is 
merely an example which should not limit the scope of the claims herein. One of 
ordinary skill in the art would recognize many other variations, alternatives, and 
modifications. Fig. 4B illustrates a flow diagram 403 having a step 412 of defining 

20 groups based upon attributes. One or more groups can be defined for the customer 
information. Attributes, such as age, income and the like can be used to define the 
groups, as described above. Once groups have been defined, then in a step 414, 
customers are assigned to the groups. The assignment can be performed based upon the 
values of the customers have for the particular attributes used to define the group. A 

25 plurality of groups can be defined for a particular set of customer data, and no particular 
definition is "correct." Rather, different definitions can be selected depending on the 
nature of the customer data and the types of analysis that are desired. 

Fig. 4C depicts a simplified flow diagram of determining step 404 of Fig. 
4A in another particular embodiment according to the present invention. This diagram is 

30 merely an example which should not limit the scope of the claims herein. One of 
ordinary skill in the art would recognize many other variations, alternatives, and 
modifications. Fig. 4C illustrates a flow diagram 405 having a step 422 of specifying an 
expression. Expressions can evaluate to specific values that can then be used to select 
which group a particular customer belongs. Next, in a step 424, values from evaluating 

11 
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the expression(s) defined in step 422 can be mapped to specific customer groups based 
upon segment code values assigned to the various groups of customers. 

Fig. 5A illustrates a representative screen for creating segmentation codes 
in a particular embodiment according to the present invention. This diagram is merely an 
5 illustration and should not limit the scope of the claims herein. One of ordinary skill in 
the art would recognize other variations, modifications, and alternatives. Fig. 5A 
illustrates a screen 501 having a Codes folder 504 under a Customer Profiling folder 502. 
The user can click the codes folder and select "New" and "code" from the menus 506. 

Fig. 5B illustrates a representative screen for creating segmentation codes 

10 in a particular embodiment according to the present invention. This diagram is merely an 
illustration and should not limit the scope of the claims herein. One of ordinary skill in 
the art would recognize other variations, modifications, and alternatives. Fig. 5B 
illustrates a screen 503 for defining an expression. Screen 503 comprises a columns pane 
510 that lists the available tables and columns to choose from for building the expression. 

15 A functions pane 512 provides functions that can be used in creating expressions. The 
aggregation functions can provide capability to produce multiple values per profile 
subject (e.g. household) which can be specified by a core table combo box 514, for 
example. The user can define the expression and then click an OK button 516. 

Fig. 5C illustrates a representative screen for creating segmentation codes 

20 in a particular embodiment according to the present invention. This diagram is merely an 
illustration and should not limit the scope of the claims herein. One of ordinary skill in 
the art would recognize other variations, modifications, and alternatives. Fig. 5C 
illustrates a screen 505 having a select segmentation method dialog box 520. Using 
dialog box 520, the user can choose from multiple methods to assign segmentation codes. 

25 For example, dialog box 520 comprises buttons for selecting segment numerically 522, 
which can be selectively performed by range using button 524 or by percentage using 
button 526. Further, dialog box 520 includes a button for selecting segment 
enumerativeiy 528. Select embodiments can include other types of segmentation 
techniques, such as ranges, Boolean expressions, arithmetic expressions, and 

30 combinations thereof without departing from the scope of the claimed invention. 

Fig. 5D illustrates a representative screen for creating segmentation codes 
in a particular embodiment according to the present invention. This diagram is merely an 
illustration and should not limit the scope of the claims herein. One of ordinary skill in 
the art would recognize other variations, modifications, and alternatives. Fig. 5D 
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illustrates a screen 507 having an example range assignment dialog 530. Range 
assignment dialog 530 comprises a plurality of columns, including a lower bound column 
532, a corresponding expression column 534, an upper bound column 536, and a 
corresponding code value column 538. 

Fig. 5E illustrates a representative screen for creating profiles in a 
particular embodiment according to the present invention. This diagram is merely an 
illustration and should not limit the scope of the claims herein. One of ordinary skill in 
the art would recognize other variations, modifications, and alternatives. Fig. 5E 
illustrates a screen 509 having a profiles folder 540 under a Customer Profiling folder 
542. The user can click the profiles folder and select "New" and "profile" from the 
menus 544. 

Fig. 5F illustrates a representative screen for creating profiles in a 
particular embodiment according to the present invention. This diagram is merely an 
illustration and should not limit the scope of the claims herein. One of ordinary skill in 
the art would recognize other variations, modifications, and alternatives. Fig. 5F 
illustrates a screen 511 having a design profile dialog box 550. Using dialog box 550, the 
user can enter a profile name into a profile name field 552. Then, the user can choose 
from multiple profile codes in a profile codes list 554 and assign them to an available 
codes list 556 using buttons 558. 

Fig. 5G illustrates a representative screen for processing a segmentation 
expression in a particular embodiment according to the present invention. This diagram 
is merely an illustration and should not limit the scope of the claims herein. One of 
ordinary skill in the art would recognize other variations, modifications, and alternatives. 
Fig. 5G illustrates a screen 513 having a Codes folder 564 under a Customer Profiling 
folder 562. The user can click the codes folder and select "Process Segmentation" from a 
menu 566. 

Fig. 5H illustrates a representative screen for processing a profile in a 
particular embodiment according to the present invention. This diagram is merely an 
illustration and should not limit the scope of the claims herein. One of ordinary skill in 
the art would recognize other variations, modifications, and alternatives. Fig. 5H 
illustrates a screen 515 having a profiles folder 560 under a Customer Profiling folder 
562. The user can click the profiles folder and select "Process profile" from a menu 564 
to "execute" the segmentation and profile plans designed previously and generate data in 
a data warehouse in a format according to the segmentation codes and profiles. 
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Fig. 51 illustrates a representative screen for deleting a segmentation codes 
in a particular embodiment according to the present invention. This diagram is merely an 
illustration and should not limit the scope of the claims herein. One of ordinary skill in 
the art would recognize other variations, modifications, and alternatives. Fig. 51 illustrates 
a screen 517 having a Codes folder 574 under a Customer Profiling folder 572. The user 
can click the codes folder and select "Delete" from a menu 576 to delete the selected 
codes. 



C O NCLUSION 

Although the above has generally described the present invention 
according to specific systems, the present invention has a much broader range of 
applicability. In particular, the present invention is not limited to a particular kind of data 
schema, but can be applied to any data model where an improved or optimized analysis is 
desired for use with customer centered data warehousing systems and applications. Thus, 
in some embodiments, the techniques of the present invention could provide access to 
many different legacy business, governmental and educational databases of all kinds. Of 
course, one of ordinary skill in the art would recognize other variations, modifications, 
and alternatives. 
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1 1 . A method for creating a customer profile from customer 

2 information stored in at least one database, said customer information comprising at least 

3 one attribute, said method comprising: 

4 receiving as input said customer information; 

5 segmenting said customer information into at least one of a plurality of 

6 groups, said segmenting based upon a value for said at least one attribute; 

7 defining at least one of a plurality of profiles; wherein said at least one 

8 profile comprises at least one of said groups; and 

9 analyzing said customer information using said customer profile. 

1 2. The method of claim 1 wherein said segmenting further comprises: 

2 defining each group in said at least one of a plurality of groups; 

3 assigning said customers into said at least one of a plurality of groups 

4 based upon said value of said attribute for said customer; wherein said partitioning 

5 assigns each customer to at most one group. 

1 3. The method of claim 2 wherein said segmenting further comprises: 

2 specifying at least one of a plurality of expressions; said expressions evaluating to said 

3 value. 

1 4. The method of claim 3 wherein said expression further comprises a 

2 plurality of said attributes, said attributes combinable based upon at least one of a 

3 plurality of operators. 

1 5. The method of claim 4 wherein said at least one operator includes 

2 arithmetic operators and logical operators. 

1 6. The method of claim 3 wherein said segmenting further comprises: 

2 mapping the values produced by said at least one of a plurality of expressions to at least 

3 one of a plurality of segmentation code values. 

1 7. The method of claim 6 wherein said mapping further comprises: 

2 assigning numeric values to particular ones of said plurality of segmentation code values. 
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1 8. The method of claim 6 wherein said mapping further comprises: 

2 assigning emimerative values to particular ones of said plurality of segmentation code 

3 values. 

1 9. The method of claim 6 wherein said mapping further comprises: 

2 mapping a range of expression values to said at least one segmentation code value. 

1 10. The method of claim 1 wherein said at least one attribute includes 

2 age and income. 
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